.main-content {
  background-color: #205da2;
}
.main-content .w {
  min-height: 22.9167vw;
  position: relative;
  align-items: center;
  display: flex;
  margin: 0 auto;
  justify-content: center;
  z-index: 1;
  padding: 2.0833vw 0.8333vw;
}
.main-content .pageHeader {
  background-position-x: 50%;
  background-position-y: 50%;
  background-image: url(https://blz.nosdn.127.net/1/tm/overwatch/ow2heroes/2600_Header.jpg);
  background-repeat: no-repeat;
}
.main-content .pageHeader .section-heroes {
  min-height: 12.5vw;
  height: 22.9167vw;
  flex-direction: column;
  max-width: 135.4167vw;
}
.main-content .pageHeader .section-heroes .part {
  margin: 0 auto;
  width: 100%;
  max-width: 72.9167vw;
  display: flex;
  color: #fff;
  justify-content: center;
  text-align: center;
  font-size: 3.125vw;
  height: 3.4375vw;
}
.main-content .heroList {
  background-image: url(https://blz.nosdn.127.net/1/tm/overwatch/ow2heroes/cloud-2600.jpg);
  margin-top: -19px;
  -webkit-mask-box-image: url(https://blz.nosdn.127.net/1/tm/blz/overwatch/home/Top_Divider-2d39cd814f.svg);
  mask-border: url(https://blz.nosdn.127.net/1/tm/blz/overwatch/home/Top_Divider-2d39cd814f.svg);
  -webkit-mask-box-image-slice: 20 350 fill;
  mask-border-slice: 20 350 fill;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  text-shadow: 0 0.2083vw 0.5208vw rgba(0, 0, 0, 0.2);
  overflow: hidden;
}
.main-content .heroList .section-list {
  flex-direction: column;
  margin: 0 auto;
  overflow: hidden;
  padding: 4.1667vw 2.0833vw;
}
.main-content .heroList .section-list .filter-header {
  justify-content: center;
  margin-bottom: 1.6667vw;
  width: 94.9479vw;
}
.main-content .heroList .section-list .filter-header .filter-list {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.2604vw;
  justify-content: center;
  height: 3.0208vw;
}
.main-content .heroList .section-list .filter-header .filter-list .filter-item {
  padding: 0.7813vw 1.5625vw;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 25%;
  border-radius: 2px;
  background-color: rgba(208, 233, 255, 0.7);
  border: 2px solid #fff;
  color: #000;
  font-weight: 700;
  min-width: 6.7708vw;
}
.main-content .heroList .section-list .filter-header .filter-list .filter-item .active {
  color: #fff;
}
.main-content .heroList .section-list .filter-header .filter-list .filter-item .filter-inner {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8333vw;
}
.main-content .heroList .section-list .filter-header .filter-list .filter-item .filter-inner img {
  max-height: 1.25vw;
  margin-right: 0.625vw;
  opacity: 0.7;
}
.main-content .heroList .section-list .filter-header .description {
  display: flex;
  justify-content: center;
  max-width: 37.5vw;
  font-size: 1.0417vw;
  line-height: 1.4583vw;
  color: rgba(255, 255, 255, 0.9);
  text-shadow: rgba(0, 0, 0, 0.2) 0 4px 10px;
  margin: 2.0833vw auto 0;
  text-align: center;
}
.main-content .heroList .section-list .filter-header .description .active {
  display: block;
}
.main-content .heroList .section-list .hero-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  margin: 0 -5px;
  max-width: 72.9167vw;
}
.main-content .heroList .section-list .hero-list .hero-card {
  display: flex;
  border: 2px solid #fff;
  border-radius: 2px;
  width: calc(20% - 10px);
  width: calc(16.6% - 1.6667vw);
  margin: 0 0.8333vw 1.6667vw;
  box-shadow: 0 2px 0.5208vw rgba(0, 0, 0, 0.1);
  background-color: rgba(255, 255, 255, 0.9);
  position: relative;
  top: 0;
  transition: all 0.3s;
}
.main-content .heroList .section-list .hero-list .hero-card .hero-img {
  position: relative;
  overflow: hidden;
}
.main-content .heroList .section-list .hero-list .hero-card .hero-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.main-content .heroList .section-list .hero-list .hero-card .hero-name {
  display: flex;
  font-size: 0.8333vw;
  font-weight: 700;
  color: rgba(0, 0, 0, 0.8);
  margin: 0.8333vw;
  justify-content: center;
  white-space: nowrap;
}
.main-content .heroList .section-list .hero-list .hero-card .hero-name .hero-role {
  margin-right: 0.5208vw;
  max-width: 1.25vw;
  max-height: 1.25vw;
}
.main-content .heroList .section-list .hero-list .hero-card .hero-name span {
  text-align: center;
}
.main-content .heroList .section-list .hero-list .hero-card:hover {
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.2);
  transform: scale(1.1);
}
.main-content .closing-background {
  background-image: url(https://blz.nosdn.127.net/1/tm/blz/overwatch/home/Desktop_Outro_Sky.jpg);
  min-height: 31.9271vw;
  width: 100%;
  height: 100%;
  position: relative;
}
.main-content .closing-background::before {
  content: '';
  background: url(https://blz.nosdn.127.net/1/tm/blz/overwatch/home/Desktop_Outro_Characters.png) no-repeat 50% 0 / cover;
  width: 100%;
  max-width: 72.9167vw;
  height: calc(100% + 3.125vw);
  display: block;
  position: absolute;
  left: 50%;
  top: -3.125vw;
  transform: translate(-50%);
  z-index: 1;
}
.main-content .closing-background .closing {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  max-width: 135.4167vw;
  margin: 0 auto;
  padding: 4.1667vw 2.0833vw;
}
.main-content .closing-background .closing .content {
  position: relative;
  max-width: 72.9167vw;
  width: 100%;
  margin: 0 auto;
}
.main-content .closing-background .closing .content .header {
  color: #fff;
  max-width: 37.5vw;
  margin: 0 auto;
  text-align: center;
  padding-top: 10.4167vw;
  z-index: 2;
  width: 100%;
  position: relative;
}
.main-content .closing-background .closing .content .header .heading {
  line-height: 3.4375vw;
  font-size: 3.125vw;
  margin-bottom: 1.5625vw;
  font-weight: 700;
}
.main-content .closing-background .closing .content .header .btn-primary {
  display: inline-block;
  background-color: #f06414;
  position: relative;
  z-index: 1;
  padding: 0 2.0833vw;
  opacity: 0.9;
  height: 3.75vw;
  line-height: 3.75vw;
  border-radius: 2px;
  color: #fff;
  font-weight: 700;
  font-size: 1.25vw;
  text-align: center;
}
